package poi

import (
	"gitee.com/kmlixh/wechat.v2/mp/core"
)

type Poi struct {
	BaseInfo struct {
		PoiId          int64 `json:"poi_id,omitempty"` // Poi 的id, 只有审核通过后才有
		AvailableState int   `json:"available_state"`  // 门店是否可用状态。1 表示系统错误、2 表示审核中、3 审核通过、4 审核驳回。当该字段为1、2、4 状态时，poi_id 为空
		UpdateStatus   int   `json:"update_status"`    // 扩展字段是否正在更新中。1 表示扩展字段正在更新中，尚未生效，不允许再次更新； 0 表示扩展字段没有在更新中或更新已生效，可以再次更新

		Sid          string   `json:"sid,omitempty"`           // 商户自己的id，用于后续审核通过收到poi_id 的通知时，做对应关系。请商户自己保证唯一识别性
		BusinessName string   `json:"business_name,omitempty"` // 门店名称（仅为商户名，如：国美、麦当劳，不应包含地区、地址、分店名等信息，错误示例：北京国美）
		BranchName   string   `json:"branch_name,omitempty"`   // 分店名称（不应包含地区信息，不应与门店名有重复，错误示例：北京王府井店）
		Province     string   `json:"province,omitempty"`      // 门店所在的省份（直辖市填城市名,如：北京市）
		City         string   `json:"city,omitempty"`          // 门店所在的城市
		District     string   `json:"district,omitempty"`      // 门店所在地区
		Address      string   `json:"address,omitempty"`       // 门店所在的详细街道地址（不要填写省市信息）
		Telephone    string   `json:"telephone,omitempty"`     // 门店的电话（纯数字，区号、分机号均由“-”隔开）
		Categories   []string `json:"categories,omitempty"`    // 门店的类型（不同级分类用“,”隔开，如：美食，川菜，火锅。详细分类参见附件：微信门店类目表）
		OffsetType   int      `json:"offset_type"`             // 坐标类型，1 为火星坐标（目前只能选1）
		Longitude    float64  `json:"longitude"`               // 门店所在地理位置的经度
		Latitude     float64  `json:"latitude"`                // 门店所在地理位置的纬度（经纬度均为火星坐标，最好选用腾讯地图标记的坐标）
		PhotoList    []Photo  `json:"photo_list,omitempty"`    // 图片列表，url 形式，可以有多张图片，尺寸为640*340px。必须为上一接口生成的url。
		Recommend    string   `json:"recommend,omitempty"`     // 推荐品，餐厅可为推荐菜；酒店为推荐套房；景点为推荐游玩景点等，针对自己行业的推荐内容
		Special      string   `json:"special,omitempty"`       // 特色服务，如免费wifi，免费停车，送货上门等商户能提供的特色功能或服务
		Introduction string   `json:"introduction,omitempty"`  // 商户简介，主要介绍商户信息等
		OpenTime     string   `json:"open_time,omitempty"`     // 营业时间，24 小时制表示，用“-”连接，如 8:00-20:00
		AvgPrice     int      `json:"avg_price,omitempty"`     // 人均价格，大于0 的整数
	} `json:"base_info"`
}

// Get 查询门店信息.
func Get(clt *core.Client, poiId int64) (poi *Poi, err error) {
	const incompleteURL = "https://api.weixin.qq.com/cgi-bin/poi/getpoi?access_token="

	var request = struct {
		PoiId int64 `json:"poi_id"`
	}{
		PoiId: poiId,
	}
	var result struct {
		core.Error
		Poi `json:"business"`
	}
	if err = clt.PostJSON(incompleteURL, &request, &result); err != nil {
		return
	}
	if result.ErrCode != core.ErrCodeOK {
		err = &result.Error
		return
	}
	result.Poi.BaseInfo.PoiId = poiId
	poi = &result.Poi
	return
}
